home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus 2000 #4 / Amiga Plus CD - 2000 - No. 4.iso / Tools / WWW / Unreal / doc / Manual < prev    next >
Encoding:
Text File  |  2000-05-27  |  14.5 KB  |  383 lines

  1. /************************************************************************
  2.  *   IRC - Internet Relay Chat, doc/MANUAL
  3.  *   Copyright (C) 1990, Karl Kleinpaste
  4.  *
  5.  *   $Id: Manual,v 1.1.1.1 2000/01/30 12:16:28 stskeeps Exp $
  6.  *
  7.  *   This program is free software; you can redistribute it and/or modify
  8.  *   it under the terms of the GNU General Public License as published by
  9.  *   the Free Software Foundation; either version 1, or (at your option)
  10.  *   any later version.
  11.  *
  12.  *   This program is distributed in the hope that it will be useful,
  13.  *   but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  15.  *   GNU General Public License for more details.
  16.  *
  17.  *   You should have received a copy of the GNU General Public License
  18.  *   along with this program; if not, write to the Free Software
  19.  *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  20.  */
  21.  
  22.                                                 Date: 04 Apr 1989
  23.                                               Author: Karl Kleinpaste
  24.                                                       karl@cis.ohio-state.edu
  25.                                                 
  26.                                    Last modification: 15 May 1992
  27.                                                   by  Mauri Haikola 
  28.                                                       mjh@stekt.oulu.fi
  29.  
  30.  
  31.              INTERNET RELAY CHAT
  32.           a real-time conversational system
  33.  
  34.  
  35. * 1: Irc - replacement for talk(1)
  36.  
  37. Irc is a functional replacement for and improvement to talk(1).  Talk
  38. is an old, primitive, atrocious, minimalist sort of keyboard/screen
  39. conversation tool, using a grotesque, machine-dependent protocol.
  40. Irc does everything talk does, but with a better protocol, allowing
  41. more than 2 users to talk at once, with access across the aggregate
  42. Internet, and providing a whole raft of other useful features.
  43.  
  44. * 2: Entering Internet Relay Chat
  45.  
  46. There are two ways to enter Internet Relay Chat. If you are using the
  47. emacs lisp client, you need to load the client into your Emacs session
  48. and then M-x irc. If you are using the C client (easier for beginners)
  49. then type (usually) irc. If you wish to be known by a nickname which
  50. is not one's login name, type `irc chosen-nickname' instead.
  51.  
  52. * 3: How much can be seen from here
  53.  
  54. The universe - seriously.
  55.  
  56. This is most formally called Internet Relay Chat.  Server hosts are
  57. connected via a tree structure.  The various servers relay control and
  58. message data among themselves to advertise the existence of other
  59. servers, users, and the channels and other resources being occupied by
  60. those users.
  61.  
  62. * 4: Structure
  63.  
  64. There is quite a lot of structure to the operation of irc, as
  65. compared to crufty old talk(1).  Since so little could be done with
  66. talk(1), it needed little structure.  But to keep track of people
  67. spread literally around the world (the system was written by Jarkko
  68. Oikarinen of Finland, usually seen on the system as `Wiz'), the
  69. structure is useful so that one can speak to exactly those people with
  70. whom one wishes to speak.
  71.  
  72. ** 4.1: Nicknames
  73.  
  74. All users of irc are known to the system by a `nickname.'  By
  75. default, one's nickname is one's login name.  Nickname clashes are not
  76. allowed; this is enforced by the servers.  If one's intended nickname
  77. clashes with someone else as one enters chat, one will not be able to
  78. complete entry to irc until one changes one's nickname to something
  79. else.
  80.  
  81. ** 4.2: Presence on a channel
  82.  
  83. Fundamental to the operation of irc is the concept of a channel.  All
  84. users are `on a channel' while inside irc.  One enters the `null
  85. channel' first.  One cannot send any messages while not in any
  86. chatting channel unless one has set up a private conversation in some
  87. way.  The number of channels is essentially unlimited - whatever will
  88. fit in a string of some ungodly length, that must start with a # sign.
  89.  
  90. ** 4.3: Main modes of channels
  91.  
  92. Public
  93.  
  94. This is the default mode for a channel. When one is on a public
  95. channel, one can be seen by all other users (if one's own user mode
  96. permits this).  Anyone can notice users on a public channel and join
  97. such a channel's conversation.
  98.  
  99. Private
  100.  
  101. This means that, although anyone can see that one is using chat, no
  102. one can tell what channel one is using unless one is already on that
  103. channel with oneself.  Since the number of potential channels is in
  104. the billions, this is quite some security - all one gives away is the
  105. acknowledgement that one is using chat.
  106.  
  107. Secret
  108.  
  109. While one is on a secret channel, no one who is not on one's channel
  110. with oneself can even see that one is there.  One's name does not show
  111. up in a list of active users.  The only indication of one's presence
  112. is that, when entering chat, all new users are told that there are "N
  113. users on P servers."  If one checks on all users and finds less than N
  114. of them, one knows that others are hiding on secret channels.  But a
  115. secret channel user still cannot be found except by brute-force
  116. checking through all channels, a hopeless proposition in the face of
  117. the huge number of possible channel names. Security through obscurity
  118. finally means something.
  119.  
  120. Changing the mode
  121.  
  122. The mode of a channel (private, secret, invite-only, moderated,
  123. topic-limited, person-number-limited, no-messages-to-channel, ban
  124. someone from channel) is set by the channel operator, who is the
  125. first person to join a channel, or someone who has had channel
  126. operatorship bestowed on them by another channel operator. 
  127.  
  128.  
  129. *** 4.4: Conversations not using channels
  130.  
  131. It is possible to conduct conversations with others without using the
  132. formalized channel structure.  Doing so requires that two people set
  133. themselves up for private conversation using special commands; see
  134. User Commands below.
  135.  
  136. * 5: Screen/keyboard structure
  137.  
  138. Chat is a full-screen utility.  It takes over the screen, with the
  139. bulk of activity happening in the top N-2 lines, a modeline (vaguely
  140. emacs-like) on the next to last line, and one's input being entered on
  141. the last line.  A very good version of client is the IRC-II client,
  142. avaliable on anonymous ftp from various sites around the world.
  143.  
  144. ** 5.1: Keyboard input
  145.  
  146. When typing commands at irc, one has a minimalist line-editing
  147. facility in an emacs style.  That is, ^A moves the cursor to the
  148. beginning of the line, ^E goes to the end, ^D deletes the character
  149. under the cursor, ^K kills from the cursor to the end, and so on.  
  150.  
  151. ** 5.2: Screen activity
  152.  
  153. Almost everything happens in the upper bulk of the screen.  This
  154. includes both messages from other users, as well as the output of the
  155. control commands.
  156.  
  157. Normal messages from other users appear with the originating nickname
  158. in <angle brackets>.  Private messages arrive with the originating
  159. nickname in *asterisks*.  Messages which one sends to everyone appear
  160. with a preceding "> " whereas messages which one sends privately to
  161. one other user appear with "-> *nickname*."
  162.  
  163. Other output (e.g., /who commands, invitations from other users to
  164. join channels, and so forth) appears interspersed with other activity
  165. on the screen.
  166.  
  167. * 6: Command structure
  168.  
  169. Ordinary text typed at irc is sent as one's messages to everyone else
  170. on the same channel, modulo personal choices for private messages and
  171. the like.  Commands to irc itself all begin with a command character,
  172. which is initially `/' but may be changed to any other character
  173. desired.
  174.  
  175. Commands may in general be abbreviated to a unique prefix.
  176.  
  177. ** 6.1: Leaving irc
  178.  
  179. The way to get out of irc is to enter the /signoff command.  "/si" is
  180. sufficient.  Also equivalent are "/exit," "/bye," and "/quit." A
  181. signoff command may include a comment which will be seen by everyone
  182. on the current channel of the person who left.
  183.  
  184. ** 6.2: Getting help
  185.  
  186. Type "/help."  Follow the instructions.
  187.  
  188. ** 6.3: User commands
  189.  
  190. The most important commands supported by irc are:
  191.  
  192.       help   signoff       who     whois
  193.       list     topic      join   channel
  194.      links       msg    invite    ignore
  195.      users     stats      nick      away
  196.       info     clear     query     cmdch
  197.       date      mode
  198.  
  199. *** 6.3.1: help
  200.  
  201. Information on how to use the rest of the system is available via
  202. /help.  The modeline says so as well.
  203.  
  204. *** 6.3.2: signoff {comment}
  205.  
  206. /signoff exits chat. Optional comment may be included; see above.
  207.  
  208. *** 6.3.3: who
  209.  
  210. /who returns information on who is using chat.  /who without arguments
  211. prints info on all users that can be seen.  Users of public channels
  212. show up with their channel identified.  Users of private channels
  213. appear, but they are specified as being on a private, unspecified
  214. channel.  Users of secret channels and users whose user mode is +i
  215. (invisible) do not appear at all.
  216.  
  217. Giving a channel name as an argument to /who returns only those users of the
  218. specified channel.  This still doesn't show users of secret channel or
  219. invisible users one is actually on the same channel with them. Users
  220. of private channels are shown, if an exact channel name is given.
  221.  
  222. *** 6.3.4: whois
  223.  
  224. This returns information about individual users.  Say "/whois
  225. nickname" to get information on the login name and host from which the
  226. nicknamed user comes.
  227.  
  228. *** 6.3.5: topic
  229.  
  230. Channels can be given off-the-cuff "topics."  Saying "/topic some
  231. string of text" will associate that topic with the current channel.
  232.  
  233. *** 6.3.6: list
  234.  
  235. /list will give lists of active channels, the number of users of each,
  236. and the topics therewith associated.  Again, secret channels do not
  237. appear and private channels only appear as Prv.
  238.  
  239. *** 6.3.7: join & channel
  240.  
  241. /join or /channel are the means to enter a channel.  Give the channel
  242. name as an argument.  If this is a secret or hidden channel, /who
  243. commands will show oneself and any other users of one's channel.
  244.  
  245. One's arrival on a channel is announced to the rest of the users
  246. already on that channel.  Silent, anonymous "lurking" is not
  247. supported.
  248.  
  249. *** 6.3.8: links
  250.  
  251. /links lists the currently-active set of chat servers.  Beware: this
  252. list can be quite long, and will undoubtedly get longer as chat gains
  253. wider use.  As of 15 May, 1992, about 130 servers is typical.
  254.  
  255. *** 6.3.9: msg
  256.  
  257. A single message can be sent privately to a certain user with /msg.
  258. Type /msg nickname and the text to be sent.  It will be sent privately
  259. to the indicated nickname.
  260.  
  261. *** 6.3.10: invite
  262.  
  263. If there is a user online to whom one wishes to speak, one may invite
  264. that user to join oneself on a certain channel.  One types "/invite
  265. nickname" with an optional channel number.  The receiving user gets a
  266. one-line message indicating the sender and the invitation.  The
  267. receiving user is free to ignore the invitation, of course.
  268.  
  269. *** 6.3.11: ignore
  270.  
  271. If one wants to ignore messages sent by some other user or users, it
  272. may be done with /ignore command. One can ignore someone by their
  273. nickname, or by their user@host data. Wildcards may be used. 
  274.  
  275. *** 6.3.12: users
  276.  
  277. /users will return a list of the users logged into one's system.  With
  278. an optional hostname identifying a chat server host, the users logged
  279. into that system will be listed.
  280.  
  281. *** 6.3.13: stats
  282.  
  283. This command returns counts of various protocol operations of one's
  284. chat server.  It is neither particularly useful nor interesting to
  285. users other than operators.
  286.  
  287. *** 6.3.14: nick
  288.  
  289. One can change nicknames by issuing "/nick new-nickname."  All users
  290. on one's channel will be advised of the change.  NOTE: If one enters
  291. chat with a nickname clash (e.g., one's login name is the same as
  292. someone else's, and the other user got there first), the system will
  293. not let one enter until one issues a /nick command with a unique
  294. nickname.
  295.  
  296. *** 6.3.15: away
  297.  
  298. Sometimes, one wishes to remain connected to the chat system, but one
  299. must be elsewhere for a while.  One can issue an /away command with
  300. arbitrary text as argument, which will mark oneself as being away.  If
  301. someone sends an away'd user a private message (via /msg or in a
  302. private session set up via /query; see below), the sender will get a
  303. message back from the server indicating the away-ness and the message
  304. which was set.
  305.  
  306. *** 6.3.16: info
  307.  
  308. /info returns information regarding the author and copyright of the
  309. chat system.
  310.  
  311. *** 6.3.17: clear
  312.  
  313. At times, one wishes that one's screen weren't so cluttered.  /clear
  314. makes it so.
  315.  
  316. *** 6.3.18: query
  317.  
  318. This command is used to set up private communications `outside' the
  319. normal channel system.
  320.  
  321. When one enters "/query nickname," the indicated nickname is set up as
  322. the sole recipient of anything which one types thereafter.  Thus, if
  323. user A executes "/query B" and user B executes "/query A," they have
  324. set up a private communication between themselves.  Significantly, it
  325. remains possible for them to stay on their respective channels, which
  326. need not be the same, and listen to whatever conversation is going on
  327. around them as well, though they cannot respond to that ambient
  328. conversation without leaving the private conversation they have set up.
  329.  
  330. One leaves this private mode by issuing /query without arguments.
  331.  
  332. *** 6.3.19: cmdch
  333.  
  334. The `/' character may not be best for some people to use as their
  335. command character.  It can be changed with "/cmdch <character>."
  336.  
  337. *** 6.3.20: mode
  338.  
  339. This command can be used for altering the various modes of a channel
  340. (see the explanation of channel modes above). /mode command can only
  341. be issued by channel operators. 
  342.  
  343. ** 6.4: Operator commands
  344.  
  345. The chat system administrators on each host have additional
  346. responsibilities and power over the configuration and operation of the
  347. servers.  The commands to do so are delineated below.
  348.  
  349. *** 6.4.1: oper
  350.  
  351. Users who have the potential for operator privileges initially invoke
  352. those privileges by "/oper nickname password," where nickname is the
  353. nickname under which operation is intended, and password is the
  354. password known to the chat system for that nickname.
  355.  
  356. *** 6.4.2: kill
  357.  
  358. Obnoxious users had best beware the operator who's fast on the /kill
  359. command.  "/kill nickname" blows any given nickname completely out of
  360. the chat system.
  361.  
  362. Obnoxiousness is not to be tolerated.  But operators should not use
  363. /kill lightly.
  364.  
  365. *** 6.4.3: quote
  366.  
  367. Raw access to the underlying server protocol is possible through the
  368. user of the /quote command.  "/quote any text at all" is used to send
  369. direct, unmodified commands to the servers.  This has a wide variety
  370. of uses, such as deliberately killing a local or remote chat daemon,
  371. invoking operator privileges for otherwise-operator-priv-forbidden
  372. users, and related tasks.  It is, again, a very powerful operation,
  373. and not to be used lightly.
  374.  
  375. * 7: Questions, problems, troubles?
  376.  
  377. If you have problems, please contact Christopher Davis (ckd@eff.org) or
  378. Helen Rose (hrose@eff.org). Known as "ckd" and "Trillian" on irc,
  379. respectively. You can also ask for help on some of the operator
  380. channels on irc, for example #twilight_zone and #eu-opers. They will
  381. be able to assist you in whatever problems you are having with IRC.
  382.  
  383.